.TH LIBPFM 3  "September, 2009" "" "Linux Programmer's Manual"
.SH NAME
libpfm_intel_x86_arch - support for Intel X86 architectural PMU
.SH SYNOPSIS
.nf
.B #include <perfmon/pfmlib.h>
.sp
.B PMU name: ix86arch
.B PMU desc: Intel X86 architectural PMU
.sp
.SH DESCRIPTION
The library supports \fbany\fR processor implementing the Intel architectural PMU. This is a
minimal PMU with a variable number of counters but predefined set of events. It is implemented
in all recent processors  starting with Intel Core Duo/Core Solo.

It acts as a default PMU support in case the library is run on a very recent processor for which
the specific support has not yet been implemented.
.SH MODIFIERS
The following modifiers are supported on Intel architectural PMU:
.TP
.B u
Measure at user level which includes privilege levels 1, 2, 3. This corresponds to \fBPFM_PLM3\fR.
This is a boolean modifier.
.TP
.B k
Measure at kernel level which includes privilege level 0. This corresponds to \fBPFM_PLM0\fR.
This is a boolean modifier.
.TP
.B i
Invert the meaning of the event. The counter will now count cycles in which the event is \fBnot\fR
occurring. This is a boolean modifier
.TP
.B e
Enable edge detection, i.e., count only when there is a state transition. This is a boolean modifier.
.TP
.B c
Set the counter mask value. The mask acts as a threshold. The counter will count the number of cycles
in which the number of occurrences of the event is greater or equal to the threshold. This is an integer
modifier with values in the range [0:255].
.TP
.B t
Measure on both threads at the same time assuming hyper-threading is enabled. This modifier requires
at least version 3 of the architectural PMU. This is a boolean modifier.

.SH AUTHORS
.nf
Stephane Eranian <eranian@gmail.com>
.if
.PP
